from django.db import models


class Area(models.Model):
    """行政区划"""
    # 创建 name 字段, 用户保存名称
    name = models.CharField(max_length=20, verbose_name="名称")
    # 自关联字段 parent
    parent = models.ForeignKey(
        "self",
        on_delete=models.SET_NULL,
        # 通过related_name字段在主表中设置隐藏属性`subs`，记录关联的多个从表对象数据
        # 如果不设置related_name，那么该隐藏属性默认是`从表模型类名小写_set`
        related_name="subs",
        null=True,
        blank=True,
        verbose_name="上级行政区划",
    )

    class Meta:
        db_table = "tb_areas"

    def __str__(self):
        return self.name
